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tat TTffF TIAIMS: 

please AMEND the claims as follows: 

Please CANCEL, claims 18 and 20-26. 

1. (Previously Amended) A computer-readable medium chaining a data 
structure defining a query definition, the data structure deluding: 

a query specification including query text and parameters, the parameters having 
values that may be set by a user before or when the query definition is 

executed; 

a results transform mat transforms results of executing the query specification into a 

canonical format; and 
a data source identifier that identifies a data source to be used when the query 

specification is executed; 

wherein the data structure encapsulates the query definition. 

2. (Original) The computer-readable medium of claim 1 wherein the results 
transform is an XSL transform. 

3. (Original) The computer-readable medium of claim 1 wherein the data 
structure is represented in XML format. 

4. (Previously Amended) The computer-readable medium of claim 1 wherein 
the data structure conforms with the following data type definition of XML: 

<!DOCTYPElens[ 

<!ELEMENT query (#PCDATA) REQUJKED> 

<!ELEMENT params (param+)> 

<!ELEMENT param (allowedvalues | props)*> 
<! ATTLIST param name CDATA REQUIRED> 
<! ATTLIST param value CDATA REQUIRED> 

<! ELEMENT formats (format*) REQUERED> 
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<1ELEMENT format (#PCDATA)> 
<! ATTLIST format name CDATA REQUIRED> 
<!ELEMENT serverurl (#PCDATA) REQUIRED> 
<!ELEMENT sort (#PCDATA)> 

<! ATTLIST sort var CDATA REQUIRED> 
<!ATTLIST sort dir (ASCpESC) REQUIRED> 



<1ELEMENT markup (p | br)*> 
<!ELEMENTp> 
O.ELEMENT br> 

<!ELEMENT crosslink (#PCDATA)> 

<! ATTLIST crosslink lens CDATA REQUIRED> 
<! ATTLIST crosslink param CDATA REQUIRED> 
<! ATTLIST crosslink valve CDATA KEQXJIRED> 
<! ATTLIST crosslink display CDATA> 



5. (Original) The computer-readable medium of claim 1 wherein the data 
structure includes a name. 

6. (Original) The computer-readable medium of claim 1 wherein the data 
structure includes a description. 

7. (Original) The computer-readable medium of claim 1 wherein the data 
structure includes a version. 

8. (Original) The computer-readable medium of claim 1 wherein the data 
structure includes an author. 
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9. (Original) The computer-readable medium of claim 1 wherein the data 
structure includes a date last modified. 

10. (Original) The computer-readable medium of claim 1 wherein the data 
structure can be used by different application programs. 

11. (Previously amended) A method in a computer-system for performing a 

query, the method comprising: 

receiving an indication of a query definition encapsulated by a data structure, the 

query definition including a query specification and a results transform; 
identifying a data source from the query specification; 

requesting execution of the query specification with fee identified data source to 

generate results in a raw format; and 
transforming the generated results in the raw format to a canonical format using the 

results transform, 

12. (Previously Amended) The method of claim 11 wherein the query definition 
includes an indication of the data source and the identifying of the data source includes 
retrieving the indication from the query definition. 

13. (Previously Amended) The method of claim 11 wherein the query 
specification includes an indication of a parameter for the query specification and the method 
includes receiving a value for the parameter, wherein the requesting of the execution of the 
query specification indicates the value of the parameter. 

14. (Original) The method of claim 1 1 wherein the query specification includes 
an indication of a parameter for the query specification and a value for the parameter. 

15. (Previously Amended) The method of claim 14 deluding updating the value 
of the parameter in response to input from a user, wherein the value is stored with the query 
specification. 
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16. (Original) The method of claim 1 1 wherein the results transform is an XSL 

transform. 

17. (Original) The method of claim 11 wherein the results transform includes 
instructions for display of the generated results. 



18. (Cancelled) 



19. (Currently Amended) The wm palm i. oadablo m pffiim methq d_ o f claim 11 IS 
wherein the data structure is represented by the following XML format: 



<!DOCTYPE FORMATTING [ 
<!ELEMENT (table)> 
<!ELEMENT value #PCDATA> 
<!ATTLIST value color CDATA> 
<! ATTLIST value style (b|i|bi|p> 
<! ATTLIST value size CDATA> 
<! ATTLIST value face CDATA> 
<! ATTLIST value dynamic (true|false)> 
<! ELEMENT table (tr*)> 

<I ATTLIST table name CDATA #REQUIRED> 
<IATTLIST table border CDATA> 
<! ATTLIST table ceUpadding CDATA> 
<! ATTLIST table cellspacing CDATA> 
<i ATTLIST table bordercolor CDATA> 
<! ATTLIST table valign CDATA> 
<!ELEMENT tr (td*)> 

<!ELEMENT td (value | table)*> 

<! ATTLIST td id CDATA #REQUIRED> 
«. ATTLIST td colspan CDATA> 
<! ATTLIST td rowspan CDATA> 
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<! ATTLIST td align CDATA> 
<! ATTLIST td valign CDATA> 
<!ELEMENT sort (#PCDATA)> 

<! ATTLIST sort var CDATA RBQUIRED> 
<! ATTLIST sort dir (ASCpESC) REQUIRED> 

<!ELEMENT markup (p 1 br)*> 
<!ELEMENT p> 
<!ELEMENT br> 

<!ELEMENT crosslink (#PCD ATA)> 

<!ATTUST crosslink lens CDATA REQUIRED> 
<! ATTLIST crosslink param CDATA REQUIRED> 
<!ATTLIST crosslink value CDATA RJEQUIRED> 
<! ATTLIST crosslink display CDATA> 



20. (Cancelled) 

21. (Cancelled) 

22. (Cancelled) 

23. (Cancelled) 

24. (Cancelled) 

25. (Cancelled) 

26. (Cancelled) 
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27. (Previously Amended) A computer-readable medium containing a data 
structure defining a query definition, the data structure comprising: 

a query specification including query text that is an expression of a query, and 

a data source identifier that identifies a data source to be used when the query 

specification is executed; 
whereby the data structure encapsulates the query definition that can be used by a 

plurality of different application programs to define a query that is to be 

executed using the query specification and the data source identified by the 

data sovixce identifier. 

28. (Original) The computer-readable medium of claim 27 wherein the data 
stmcmre further includes a results transform for transforming results of me execution of the 
query to a canonical format 

29. (Original) The computer-readable medium of claim 28 wherein the results 
transform is an XSL transform. 

30. (Original) The computer readable medium of claim 27 wherein the data 
structure is represented in XML format. 

31. (Previously Amended) The computer-readable medium of claim 27 wherein 
the query specification includes one or more parameters, each of the one or more parameters 
having one or more values that may be set by a user before or when the query is executed. 

32. (Previously Amended) The computer-readable medium of claim 31 wherein 
the query specification includes one or more possible values for one or more of the 

parameters. 

33. (Previously Amended) The computer-readable medium of claim 27 wherein 
the query specification includes one or more sort variables for ordering of the results of the 
query. 
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34 (Previously Amended) The computer-readable medium of claim 27 wherein 
execution of the query produces the same query results for each appUcation program. 

35. (Previously Amended) A computer-readable medium containing instructions 
for controlling computer systems to execute queries by a method comprising: 

receiving a query definition that includes a query specification and a data source 
identifier, the query definition being encapsulated by a data structure mat can 
be accessed by a plurality of different application programs; and 

requesting execution of the query definition to generate results. 

36 (Previously Amended) The computer-readable medium of claim 35 wherein 
the query definition includes a results transform, the method farther including using the 
results transform to transform the generated results from a raw format to a canonical format 

37. (Original) The computer-readable medium of claim 36 wherein the results 
transfonn is an XSL transform. 

38. (Original) The computer-readable medium of claim 35 including transforming 
the generated results from a raw format to a canonical format. 

39. (Original) The computer-readable medium of claim 35 wherein the query 

definition is a lens file. 

40. (Original) The computer-readable medium of claim 35 wherein the query 
definition is stored in a single file. 

41. (Original) The computer-readable medium of claim 35 wherein the results are 

in a canonical fbimat 

42. (Previously Amended) The computer-readable medium of claim 35 wherein 
the requesting of execution of the query includes invoking a function of a first interface that 



returns a 



second interface for retrieving the results a portion at a time. 
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43. (Previously Amended) The computer-readable medium of claim 42 wherein 
the first API is the Hens interface. 

44. (Original) The computer-readable medium of claim 42 wherein the second 
interface is the IChunks interface. 

45. (Previously Amended) A computer system for executing queries, the 

computer system, comprising: 

means for receiving a data structure encapsulating a query definition that includes a 

query specification and a data source identifier; and 
means for requesting execution of Iho query definition to generate results using the 
query specification and a data source identified by the data source identifier. 

46. (Original) The computer system of claim 45 wherein the query definition 
includes a results transform and including using the results transform to transform the 
generated results from a raw format to a canonical format. 

47. (Original) The computer system of claim 46 wherein the results transform is 
an XSL transform. 

48. (Original) The computer system of claim 45 including trar*forming me 
generated results from a raw format to a canonical format. 

49. (Original) The computer system of claim 45 wherein the query definition is a 
lens file. 

50. (Original) The computer system of claim 45 wherein the query definition is 
stored in a single file. 

51. (Original) The computer system of claim 45 wherein the results are in a 
canonical formal. 
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52. (Withdrawn) A method in a computer system for generating a data structure 
defining a query definition, the method comprising: 

storing in the data structure a query specification including query text that is an 

expression of the query; and 
storing in the data structure a data source identifier that identifies a data source to b e 

used when the query definition is executed 
whereby the data structure is in a portable format that can be used by a plurality of 

different application programs to execute the query definition. 

53 (Withdrawn) The method of claim 52 including storing in the data structure a 
results transform for transforming results of the execution of the query definition to a 
canonical format, 

54. (Withdrawn) The method of claim 52 including storing in the data structure 
indications of parameters whose values may be set when the query definition is executed. 

55. (Withdrawn) The method of claim 54 including storing in the data structure 
possible values for the parameters. 

56. (Withdrawn) The method of claim 54 wherein the query text may be modified 
before execution when a value for a parameter is not specified. 

57. (Withdrawn) The method of claim 52 including storing in the data structure 
sort variables for controlling ordering of the results of the query. 

58. (Withdrawn) A method in a computer system for adjusting a query expression 
based on a parameter value not being specified at execution time, the method comprising: 

receiving a query expression along with an indication of a parameter that may be 
specified before executing the query expression; and 

when the query expression is to be executed without a value of the parameter being 
specified, 

modifying the query expression to remove a portion of the query expression 
mat depends on the parameter, and 
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executing the modified query expression. 

59 (Withdrawn) The method of claim 58 wherein the query expression includes 
query sub-expressions and the modiiying includes removing a query sub-expression that 

depends on the parameter. 

60. (Withdrawn) The method of claim 58 wherein the query sub-expressions are 
combined by a logical-AND. 

61. (Withdrawn) The method of claim 58 wherein the query sub-expressions are 
combmed by a logical-OR- 

62. (Withdrawn) A computer system for adjusting a query expression based on a 
parameter value not being specified at execution time, the computer system comprising; 

means for receiving the query expression along with an indication of a parameter, the 

query expression having query sub-expressions; and 
ro eans for modifying the query expression to remove a query sub-expression that 

depends on the parameter when the query expression is to be executed without 

a value of the parameter being specified; and 
means for executing the modified query expression. 

63. (Withdrawn) The computer system of claim 62 wherein me query sub- 
expressions are combmed by a logical-AND. 

64. (Withdrawn) The computer system of claim 62 wherein the sub-expressions 
are combined by a logical-OR. 

65. (Previously Amended) The computer-readable medium as recited in 
claim 1, wherein the query definition can be executed via an API. 

66. (Previously Amended) The computer-readable medium as recited in 
clahn 65, wherein the API provides one or more functions for accessing the query definition. 
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67 (Previously Amended) The computer-readable medium as rented in 

claim 65, where* the API^^ 

^cuonforsettmgoneormorev^ 

definition, and a function for executing the query definition. 

68 (Previously Presented) The computer-readable medium as recited in 
claim 1, wherein each of the parameters includes an ignore attribute, the ignore attribute 
indicating whether the parameter is to be used in the query. 

69 (Previously Presented) The computer-readable medium as recced in 
claiml.whe^moneor 

70. Obviously Presented) The computer-readable medium as recited in 

claim 1, further comprising; 

a sort indicator indicating a manner in which the results of executing the query are to 

be sorted, 

71 (Previously Fresemed) Thft computeMeadable medium as recited rfi. 
cto l,^^c^fb m a.inc 1 ud= S atle aS to„ e ofav» 1 uM*lc.-dn^«^. 

72 (PreviouslyPresemed) lie cwnpWerWable medium as recited in 
e to 7 1 .whe^tbevah«h U atIeas t on.of.color >sW le. S i^f6n,andd^at tn bute. 

me dynamic ^^irtic^*^^^*^^^^ 0 ***" 

query specification. 

73 (Previously Presented) The computer-readable medium as recited in 
claim 1 , wherein the canonical format includes a sort tag indicatmg a variable or parameter 
according to which the results are to be sorted. 

74 (Previously Amended) The computer-readable medium as recited in 
claim 73, wherein the results are to be sorted accoxding to the variable or P^meter when a 
specified value is selected or specified by a user for the variable or parameter. 
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75 (Previously Presented) The computer-readable medium as rented m 
more query definitions having a particular value for one or more of the parameters. 

76 . (Previously Presented) The computer-readable medium as recited in 

claim 1, wherein the canonical format comprises: 

a table element having one or more row elements and one or more columns; 
far each of the one or more row elements, one or more data elements, each data 
element corresponding to one of the one or more columns of the table 
element; and 

^ ■ A vnln^q or table elements with row elements and 

each data element having one or more values or tame cicmwx 

data elements. 

77 (previa* Amended) Themelnodastecitedinclatall.whereinihe 
itotifting of the data soon* includes olrtainmg a d*a source id«nn«r identifying the data 

source via an API. 

78. (Previously Amended) The method as recited in claim 11, wherein the 
query definition can be executed via an APL 

79. (Previously Amended) The method as recited in claim 78, wherein the 
API provides one or more functions for accessing me query definition. 

80 (Previously Amended) The method as recited in claim 78, wherein the 
APIprovides at least one of a function for loading a query definition, a function for setting 
one ormore values of one or more parameters of the query defimnor, and a function for 

executing the query definition. 

81 (Previously Presented) The method as recited in claim 11, wherein each 
parameter of the query definition includes an ignore attribute, the ignore attribute indicating 
whether the parameter is to be used in the query. 

82. (Previously Presented) The method as recited in claim 11, wherein one 
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or more 



parameters of the query defmtion has one or more a*od*ed allowed vahres. 



S3 (PreviouslyPresented) tt*method as recited in claim 11, wherein the 

executing the query are to be sotted. 

84. <Prevfo,*lyft«ented> Themefhod as recited in claim 11. wherein the 
canonical format include, at least one of a value, table, and markup tags. 

85 (PreviouslyPresented) The method*, recited in claim 84, wherein the 

. ^ue to. at least one of a color, style, size, font, and dynamic attrmute. the dynamic attribute 
Seating whemer me value is dyr^y general by oxecutmg me query spectneatton. 

86 (PreviouslyPresented) Themethod as recited in claim U.whereto the 

results are to be sorted, 

87 (Previously Amended) The method as recited in claim 86., wherein the 
results are to be sorted according to *e variable or parameter when a specified value * 
selected or specified by a user for the variable or parameter. 

88 (PreviouslyPresented) The me*od as recited in claim 11. wherein the 
having particular value for one or more parameters of the query deflation. 

89 . (PreviouslyPresented) The method as recited in claim U.wherein the 

canonical format comprises: 

ataWe element navi^ one 

for each of the one or more row elements, one or more data elements, each daU 
element corresponding to one of the one or more columns of the table 
element; and 

e^h data element having one or more values or table elements with row elements and 
data elements. 
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